#include<bits/stdc++.h>
using namespace std;
int n,m,k,p,a[2005],num;
long long ans=1,mod=1e9+7;
int A(int x){
if(x==a[x])return x;
a[x]=A(a[x]);
return a[x];
}
int main(){
cin>>n>>m>>k;
num=n;
for(int i=1;i<=n;i++)a[i]=i;
for(int i=1;i<=n-k+1;i++){
for(int I=i,J=i+k-1;I<J;I++,J--){
if(A(I)!=A(J))num--;
a[a[I]]=A(J);
}
}
for(int i=1;i<=num;i++)ans*=m,ans%=mod;
cout<<ans;
return 0;
}
Char Sum | Two Strings |
Anagrams | Prime Number |
Lexical Sorting Reloaded | 1514A - Perfectly Imperfect Array |
580A- Kefa and First Steps | 1472B- Fair Division |
996A - Hit the Lottery | MSNSADM1 Football |
MATCHES Playing with Matches | HRDSEQ Hard Sequence |
DRCHEF Doctor Chef | 559. Maximum Depth of N-ary Tree |
821. Shortest Distance to a Character | 1441. Build an Array With Stack Operations |
1356. Sort Integers by The Number of 1 Bits | 922. Sort Array By Parity II |
344. Reverse String | 1047. Remove All Adjacent Duplicates In String |
977. Squares of a Sorted Array | 852. Peak Index in a Mountain Array |
461. Hamming Distance | 1748. Sum of Unique Elements |
897. Increasing Order Search Tree | 905. Sort Array By Parity |
1351. Count Negative Numbers in a Sorted Matrix | 617. Merge Two Binary Trees |
1450. Number of Students Doing Homework at a Given Time | 700. Search in a Binary Search Tree |